草庐IT

python - Django中同一模型的多个多对多关系

全部标签

ruby-on-rails - Rails - 如何在不重复的情况下为多个角色声明 attr_accessible

有没有一种方法可以为多个角色声明attr_accessible而无需大量重复?如果我有多个用户角色,并且允许每个角色编辑不同的属性子集,那么我的attr_accessible声明如下所示:attr_accessible:first_name,:last_name,:active,:as=>:adminattr_accessible:first_name,:last_name,:as=>:managerattr_accessible:first_name,:last_name,:as=>:guest我也愿意A)定义一组可以共享的可访问属性不同的角色或B)定义一组可以访问相同角色的角色属性

ruby-on-rails - 如何强制 Rails 加载所有模型?

Rails按需加载模型。对于我正在编写的rake任务,我需要能够遍历所有ActiveRecord::Base实例(这可以通过ActiveRecord::Base.send(:subclasses))。但是,要使上述工作正常,它们必须已经加载。有人知道强制加载所有模型的方法吗?理想情况下,我不想浏览app/models,因为我也想捕捉插件添加的模型。 最佳答案 我需要为检查所有记录有效性的rake任务加载所有模型,并找到了方便的方法eager_load,可以像这样简单地使用:Rails.application.eager_load!

ruby-on-rails - 尝试使用 Rails 和 PostgreSQL 生成模型时,命令挂起且没有错误

当使用这个命令时:rails生成模型事件名称:字符串没有任何反应,我必须按CTRL+c。我使用的版本是:ruby2.1.1p76rails4.1.0PostgreSQL9.3.4MacOSX10.9.3我已验证Postgres正在运行,我可以通过运行psqleasyEventTracker_development连接到它。我通过运行railsneweasyEventTracker-dpostgresql来设置我的Rails项目运行rakedb:create时,我收到以下消息:easyEventTracker_developmentalreadyexistseasyEventTracke

ruby-on-rails - 将路由文件拆分为多个文件

我正在使用Rails3应用程序工作,我想根据子域将路由拆分为单独的文件。现在我的routes.rb文件中有这个:Skateparks::Application.routes.drawdoconstraints(:subdomain=>'api')doload'routes/api.rb'endend在我的routes/api.rb文件中我有:resources:skateparks这似乎不起作用,因为如果我运行rakeroutes我明白了undefinedmethod`resources'formain:Object此外,如果我尝试导航到http://0.0.0.0:3000/我得到:

ruby-on-rails - 如何将 ActiveRecord 表名转换为模型类名

是否有可能将ActiveRecord表名正确转换为模型类名?我发现了一个黑客defmodel_for_table(table_name)table_name.classify.constantizeend但是由于我们对我们的许多模型使用set_table_name,所以这行不通。有什么办法吗? 最佳答案 我做到了!这将以“table_name”=>“model_class_name”的形式返回一个散列。Hash[ObjectSpace.enum_for(:each_object,class编辑:更好的版本(仅适用于Rails3):H

ruby-on-rails - 多个数据库的测试和 database_cleaner

我们有一个邮箱模型,它使用另一个邮件应用程序也连接到的辅助数据库。这称为使用establish_connection:mail_database现在,我想我可以尝试将它包装在if语句中,以便它为测试环境使用不同的连接,但我想知道如何保持这个数据库的清洁,最好使用我们已经将其用于“常规”数据库的database_cleaner。我希望有人能将我推向正确的方向。 最佳答案 我有一个使用rspec(2.12.0)和使用database_cleaner(0.9.1f4b44bb)测试的rails3.2.10应用程序,它有两个用于mysql的

ruby - 从 map 返回多个值

有什么办法可以做到:a=b.map{|e|#returnmultipleelementstobeaddedtoa}不是为要添加到a的每个迭代返回单个对象,而是可以返回多个对象。我目前正在通过以下方式实现这一目标:a=[]b.map{|e|a.concat([x,y,z])}有没有办法在一行中完成此操作而无需预先声明a=[]? 最佳答案 使用Enumerable#flat_mapb=[0,3,6]a=b.flat_map{|x|[x,x+1,x+2]}a#=>[0,1,2,3,4,5,6,7,8]

ruby - 使用 YARD 记录模型属性

我正在使用YARD使用makrdown作为脚本解析器为我的Rails应用程序生成文档。大多数文档功能开箱即用。但是,我还想将模型属性记录为一个,记录模型上的可用属性列表和两个,以描述它们的语义。我无法在YARD中找到对此的任何特殊支持,我基本上只能在类注释中简单地列出属性。有没有办法记录动态生成的模型属性,以便它们像标准属性/方法一样出现在文档中?附言我已经使用annodate-modelsgem在类列表的顶部生成基本模式转储,但这并不是我真正想要的。 最佳答案 似乎YARD现在有自己的@!attribute(注意感叹号)标签用于此

ruby-on-rails - Rails 4 按模型方法求和

在我的应用程序中,我有一个User模型,带有goal_ytd方法,执行一些计算。在Controller中,我有一个变量@users那可能是User或ActiveRecord::Relation的users,我想总结所有@users的goal_ytd我的第一个倾向是:@users.sum(&:goal_ytd)因为使用sum在这两种情况下都抛出了弃用警告在ActiveRecord::Relation上将在Rails4.1中消失。因此,我将代码更改为:@users.to_a.sum(&:goal_ytd)然后抛出一个NoMethodError因为,在某种情况下,@users由@users=

ruby-on-rails - Rails:PG::InsufficientPrivilege:错误:关系 schema_migrations 的权限被拒绝

我正在尝试在Rails中创建数据库。在Postgres中,我看到了开发和测试数据库,但是,我遇到了权限错误。我试过点击此链接,但对我不起作用。错误:PG::InsufficientPrivilege:错误:关系schema_migrations的权限被拒绝:SELECT"schema_migrations".*FROM"schema_migrations"Rails:permissiondeniedforrelationschema_migrationsdefault:&defaultadapter:postgresqlencoding:unicodepool:5host:localh